package com.zhj.algorithm.sort;

/**
 * @PackageName:com.zhj.algorithm.sort
 * @ClassName:Bubble
 * @auter: 朱慧杰
 * @date:2020/7/16 0016 21:16
 **/
public class BubbleSort {

    /**
     * 对数组a中的元素排序  ----冒泡排序
     * @param a
     */
    public static void sort(Comparable[] a) {

        for(int i = a.length-1; i > 0; i--) {
            for (int j = 0; j < i; j++) {
                // 时间复杂度 O(n^2)
                if(greater(a[j] , a[j+1])) {
                    exch(a, j, j+1);
                }
            }
        }

    }

    /**
     * 比较v元素是否大于m元素
     * @param a
     */
    public static boolean greater(Comparable v, Comparable w){
        return v.compareTo(w)>0;
    }

    /**
     * 数组元素i 和 j 交换位置
     * @param a
     */
    public static void exch(Comparable[] a, int i, int j) {

        Comparable temp;

        temp = a[i];
        a[i] = a[j];
        a[j] = temp;

    }

}
